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(54) Titk: PRINT OPTION TOR WAP BROWSERS 



2 (S7) Alisiract: The WAP browser in a mobile phone is adapted to permit printing of WML data received and interpreted by The 
WAP browser. The mobile plione has conu-ol circuitxy. including a processing unit, a memory connected to the processing imit, and 
^ a display. Tlic WAP browser is adapted to interpret received Wireless Markup L^guage (WML) data and display it on the display. 
^ The WAP brow.wr includes a print option which, when selected by the user of the wireless communication device, causes The WML 
^ data to be prinud. 
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PRINT OPTION FOR WAP BROWSERS 
TECHNICAL FIELD 

Tlie present invention relates generally to mobile phones. Jn particular, it relates to mobile 
phones having a WAP browser. 

Unlike personal computers, mobile phones typically have unique internal technology and 
only a small fraction of the resources of a typical desktop or portable computer. Tliis means that the 
feaiures in the phone are very limited compared to a computer. The reason for this limitation is the 
size ofthe phones, ie. the phone has a severe limitation in processing power, memory space, display 
si'/e and buttons or keys by which a user can request, view and manipulate information obtained from 
a hypermedia server. Therefore, it is very important that the features in the phone arc made as 
efficient as possible. Also, the relatively high cost for a call from a cellular phone makes it very 
important to quickly carry out associated functions. 

Despite these limitations, mobile phone have nevertheless been growing rapidly in computing 
power and can now perform many functions in addition to voice telephony. They can, for example, 
access remote data services, such as banking, stock quotes and weather forecasts, with Short 
Messaging Ser\'ice (SMS) and Wireless Application Protocol (WAP). 

WAP 1 . 1 is a result of continuous work to define an industry wide standard for developing 
applications over cellular communication networks. The WAP 1.1 Specification Sheet is available to 
the public at www.wnpforum.org/what.tcchnical.htm and is hereby incorporated by reference. WAP 
1 . 1 makes it possible to access, for example, the Internet or other kind of infonnalion networks 
provided with hypemiedia servers, from an ordinary cell phone supporting WAP. However, The 
WAP I . I Specification Sheet is concerned only with document encoding, transmission and decoding; 
there is no discussions of the use of downloaded documents. 

WAP is very similar to the current Internet standards. The Internet utilizes a Hypertext 
Markup Language (HTML), e.g. Java Script, a Hypertext Transfer Protocol (HTTP), Transport . 
Layered Security (TLS)/Secure Sockets Layer (SSL), and a Transport Configuration Protocol (TCP)/ 
User Diagram Protocol (UDP). WAP comprises a Wireless Markup Language (WML) corresponding 
to HTML, a Wireless Session Layer (WSP) corresponding to HTTP, a Wireless Transport Layered 
Security ( WTLS) corresponding to TLS/SSL, and a Wireless Transport Layer (WTP) corresponding 
to TCP/UDP. THE core of WAP is WML and WML Script, which are interpreted by using a 
browser resident on The mobile device. Furthermore, WAP comprises different bearers like, for 
example, SMS, USSD, and CDMA. It is also possible to implement different kinds of services and 
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applications in WAP, e.g. Value Added Services (VAS). 

Although software applications in the personal computer environment are well developed and 
robust, ihe software in a mobile phone can sometimes be written in a relatively uncommon language 
and programmers may have difncully working with thai language. Consecjuenlly, each new function 
5 in the phone, even functions which are relatively simple in other environments, like storing and 

printing data, is difficult to implement since ii must utilize very limited resources, involves low level 
programming and depends on the phone's internal architecture. 

Mobile phones also lack the serial, parallel, and USB port.?, ethemet connections and other 
intcrHiccs common on personal computers. Tliere are thus additional difficulties in carrying out 
10 functions, like printing, that require an external device. While there are some wireless infrared 
methods of transferring data between mobile devices, such as IrCOMM (wwwjrda orc) and 
Bluetooth (www.bliieiooth.com). they have underlying protocols which define standard ways to 
tran.ster ihe data. These methods do not define a protocol that works at the uppermost data layer and 
is understood by both devices. Consequently, there are difficulties in printing data in WML format. 
1 5 Other devices, such as Personal Digital Assistants (PDAs), can print by themselves or can print 

through a desktop computer. But these devices utilize a HTML browser, such as Pocket Explorer 
from Microsoft, rather than a WAPAVML browser and can thus use the printing functions available 
in such a conventional browser. 

Printing mobile phones with browsers is also difficult since the visual part of user interfaces 
20 for mobile phones is not standardized and WML content can be shown in different ways. Every 

mobile phone breaks the text and other parts of the content into several lines in its own way. Printers 
have much wider lines than mobile phones and can print the text in a more readable fonnat. 

• The present invention addresses mobile phones with browsers. There are several different 
a.spects and objects of the invention. However, the invention is not limited thereto. A particular 
25 implementation of the invention may apply an combination of the aspects and objects of the 
invention, such that some aspects and objects of the invention may be practiced in a particular 
implementation of the invention even though some other aspects and object are not practiced in the 
panicular implementation. 

An object of the invention is to provide optimal data handling extensions for the browser of a 
30 mobile phone to allow additional printing functions. An embodiment of the invention adds the 
priming functions in the source code of the browser. 

One object of the invention is to provide printing capabilities for a mobile phone as a 
software functionality without adding additional hardware (such as button on a keypad). For 
example, an embodiment of the invention is implemented by being included in the operating system 
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software of the mobile phone. 

Another object of (he invention is to make use of a printing facility that is well integrated into 
the mobile phone and which can be shared by different sub-sysicms of the device. For example, one 
embodiment of the invention extends the same printing facility used for printing a phone book or 
5 calendar to additionally print The WML content from a WAP browser as well. 

A further object of the invention is to provide a mobile phone that is capable of printing a 
variety of types of data, including WML content, on a separate printer via a direct infrared 
communication link to that printer. 

According to an exemplary embodiment of the invention, The WAP browser in a mobile 
10 phone is adapted to permit printing of WML data received and interpreted by The WAP browser. 
The mobile phone has control circuitry, including a processing unit, a memory connected to the 
processing unit, and a display. Tlie WAP browser is adapted to inieipret received Wireless Markup 
Lanuuage (WML) data and display it on the display. The WAP browser includes a print option 
which, when selected by the user of the wireless communication device, causes The WML data to be 
15 primed. 

BRIEF DESCRIPTION OF THE DRAWINGS 
I'ig. 1 is a graphical illustration of the preferred implemeiitalion of the invention to print data 
from a WAP device. 

20 Fig. 2 is a generalized block diagram of a mobile phone with a WAP browser and a display 

according to one aspect of the invention. 

Fig. 3 is a block diagram useful for illustrating a process of decoding and printing data in a 
mobile phone according to an example embodiment of the invention. 

25 BEST MODE FOR CARRYING OUT THE INVENTION 

1lie foregoing and a better understanding of the present invention will become apparent from 
the following detailed description of example embodiments and the claims when read in connection 
with the accompanying drawings, all forming a part of the disclosure of the invention. Wlule the 
foregoing and following written and illustrated disclosure focuses on disclosing example 

30 embodiments of the invention, it should be clearly understood that the same is by way of illustration 
and example only and is not to be taken by way of limitation, the spirit and scope of the present 
invention being limited only by the terms of the claims in the patent issuing from this application. 

The preferred embodiment of the invention seeks'lo provide an integrated printing extension 
for a WAP browser in a mobile phone. The invention of course is not limited to such a specific 
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embocliiiiehl. It is more broadly directed tu any of a diverse set ol' VVAP-enabled mobile phones 
having a user agent for interpreting downloaded data. 

[* ig. I is a graphical illustration useful for showing an application of the preferred 
embodiment of the invention and for contrasting it with a conventional method. According to the 
S invention, WML formatted content downloaded by a WAP device 100 is primed on a separate primer 
120 via an infrared link 1 10. This is in contrast to the conventional process of downloading H I ML 
format data on a personal computer (PC) with internet browser 130 and printing it via an ethemet, 
serial or parallel interface. 

The WAP device 100 differs from the personal computer with internet browser 130 in that it 

1 0 generally has a less powerful CPU, less memory, restricted power consumption, smaller displays and 
more limited input devices. The cellular network differs from the Internet network in that it generally 
has le.s.<; bandwidth, more latency, less connection stability and less predictable availability. 
Communicaiion between WAP device 100 and a WAP gateway, connected in turn to at least one web 
server, is according to the Wireless Application Protocol (WAP). WAP specifies an application 

1 S framework and network protocols for cellular tenninals such as mobile telephones, pagers, and 
per.«;onal digital a.ssislants. WAP brings Inicmel content and advanced data services to cellular 
tenninals. It is optimized for narrow bandwidth bearers with potentially high latency and is 
optimized for efficient use of WAP device resources. WAP can work across differing cellular 
network lechnologies and bearer types (GSM, CDMS, SMS). 

20 WAP defines a set of standard protocols that enable communication between mobile 

terminals and network servers. WAP uses a standard naming model according to which standard 
Internet UKLs arc used to identify content on servers. It also uses content typing. All WAP content 
is given a specific type consistent with WWW typing which allows a cellular terminal to correctly 
process the content based on type. WAP also uses standard content formats and standard 

25 comnuinicaiion protocols. 

Mobile Phone Architecture 

WAP device 100 is preferably implemented as a mobile phone having a keypad, a display, an 
on/off button, a S|>eaker, and a microphone. It is preferably adapted for communication via a cellular 
30 telecommunication network, e.g. a cellular network. However, the phone can also be designed for a 
cordless network. The keypad has a first group of twelve alphanumeric keys, by means of which the 
user can enter a telephone number, write a text message (SMS), write a name (associated with the 
phone number), etc. Each of the keys is provided with a figure "0-9" or a sign or 
respectively. In alpha mode, each key is associated with a number of letters and special signs used in 
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various resources of llic mobile phone, and provides coinmunicalion facilities for various peripheral 
uniis, such as tlic priming facility. 

Coiurol circuitry 203 communicaics wiih a standard cellular transceiver 20 1 connecting it to, 
and sidapied lo send/receive a request/respond to/from, a teleconinuinication network. The audio part 
5 speech-decodes (he signal,. which is transferred from the control means to the earpiece via a D/A 
convener (noi shown). Control circuiir>' 203 also communicates with an infrared (ir) or Bluetooth 
wireless port 202 enabling it to directly send data to another device via a wireless infrared 
connection. Port 202 contains the appropriate drivers for establishing a connection with anoth4er 
device, such as a primer. Although display 207 is shown separately in Fig. 2 for simplicity, it is 

10 preferably lonncd imegrally with the mobile phone. 

The control circuitry 203 monitors the activity in the phone and controls the display in 
response thereto, fherefore. it is the control circuhry 203 which detects the occurrence of a stale 
chcumc L veni and changes the state of the phone and thus the display text. A state change event may 
be cau.seJ by the user when he activates the keypad including the navigation key. and these types of 

1 5 events are called entry events or user events. However, the network communicating with the phone 
may also c:»u.se a stale change event. This type of event and other events beyond the user's control are 
called non-user events. Non-user events comprise status change during call set>up, change in battery 
voltage, change in antenna conditions, message on reception of SMS, etc. 

20 Browser Operation 

A Wireless Application Environment which fomjs an upper layer of The WAP stack includes 
a browser applicriiion, also called a micro-brow.ser. Tlie browser uses Wireless Markup Language 
(WML), a lightweight markup language, ;ind WML Script a lightweight scripting language. The 
browser application i.s arranged to establish a session by reading an item in flash ROM 205. The user 

25 interface is connected lo the browser application having a display for displaying content and user 

input meatis for control the browser. The browser can be amingcd in Hash ROM 205 or in SIM card 
206. 

A preferred embodiment of the invention is that a script in Hash ROM 205 can actix'ale or 
download linking applications, i.e., an application which makes it possible to receive and/or transmit 
30 different types of data to WAP device 100. For example, the different types of data packets can be a 
particular text format, software programs, picture formats. This allows the processing power of the 
tenniital to be rc«;tricied. allows a standard WAP browser to be used and provides flexibility for new 
feature.^;. This is preferably done by creating extensions to WML and WML script. Thus, the script 
can make is possible to access data packets, which might not be supported by the software in the 
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lemiiiial, by downloading the appropriale application, supporting the type of data format, directly to 
the terminal. The content of the data packet can be displayed, stored, interpreted and/or printed by 
infrared iransniissioa directly to the printer. 

It is preferable to provide one or more distinct linking applications in flash ROM 205 of 
5 WAP device 100 prior to establishing communications. This is typically done during the 

manufaciuro of WAP device 100, wherein the linking application can be a software program 
controlling access to the server. A varieiy of other software applications can also be included and 
siored in fish ROM 205. 

In another aspecl of the invention, RAM 204 is arranged lo copy items from a session. 
10 Typically, RAM 204 can be a cache memory, which means that t)je items from the latest session can 
be temporarily saved in the second memorv'. As an ahemative, the items from a session can be saved 
in a pennanenl storage memory, which means that the user is able to confirm if the items are going to 
be saved or deleted. The permanent stora«;e memory can be SIM card 206 and/or flash ROM 205. 

When the mobile phone of the preferred embodiment is activated, the user may select a 
1 5 browser menu on a display controller by the browser application. In this browser menu the user can 
choose to establish a session to a server. To establish the session the user selects the service 
connected lo the server from the menu. The selection is done by e.g. pressing on one of the sofi keys. 
When the server sends requested inibrmaiion, it is interpreted by the browser application and 
displayed on display 207. Preferably, display 207 is an liquid crystal display (LCD). 

20 

User Interface 

Display 207 of WAP device 100 can be controlled by control circuitry 203. When the phone 
is activated and awaiting an action, e.g., an incoming or outgoing call, an idle mode is displayed. In 
the bottom of the display, there is two items which are denoted as *'Menu" 55 and "Names" 60. If the 

25 user selects "Names^\ he/she can e.g. access a built in phone book. If the user selects "Menu" 55, 

he/she can .select among several different menus. The actual selection of features in the bottom of the 
display, like "Menu" and "Names", can be selected by means of the soft keys. One of the menus can 
be the next display called "Browser": If the user chooses to use this menu, he/she can access 
different telecom related information ser\ ices, e.g. Internet, using WAP. 

30 During operation, the browser displays a number of options on display 207 of the mobile 

phone. These options may include the conventional options of clear cache, exit, bookmarks, home 
page. etc. In an exemplary embodiment, these options arc shown al a place on the dijjplay that is 
associated wiih the soft keys of the phone. The print option is preferably shown at the .same place 
where these other options are shown and selected. 
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When the prim option is sclecied, ihe prini faciliiy feature iniegraied into the source code of 
I he openiliiig sysicnj causes the control circuitr>' 203 to perform the various functions necessary to 
accomplish printing of the received WML data, l-irst, the control circuito' 203 accesses the area in 
menu)r>' where the browser stored the downloaded WML data. I he data is preferably stored in the 
5 menior>' in encoded formal. An additional area is then set aside in memory where The WML data is 
prepared to be pi inied. When the user chooses to print a page, the program decodes The WML data 
again but into the additional area set aside in memory instead oflhe display. If necessary, the print 
facility uiili/.es the identifier of The WML data also stored in the memory and representing different 
types of data as discussed above. 

10 A» twample oflhe operation ofilie priming facility is provided in Fig. 3. While a block 

diagram Ibnn is employed in Fig. 3 to represent The WML decoder 301 and other elements oflhe 
printing raciliiy, ii should not be misinteri)reied that the elements are necessarily implemented as 
hardware components. Tlie blocks are chosen so as to best illusiraic the parts of the process and the 
various elements can be implemented in any number of different ways, including, but not limited to, 

15 software. 

WML decoder 301 receives a decode request for downloaded WML data from cellular 
transceiver 201 ofihe mobile phone. The WML data may be immediately decoded or may be 
temporarily stored in WML cache 302 prior to decoding. ITie WM L cache 302 is preferably 
organized in sizes so as to facilitate the quick storage and retrieval of entire pages of WML data at 

20 one time. A display module 303 includes a display memory 303- 1 and user interface routines 303-2 
for the display 207. The user interface routines 303-2 handle the user actions and input fields oflhe 
user interface and translates them so that they can be used by the operating system software of the 
mobile phone. A printing module 304 contains a print buffer 304- 1 and printing routines 304-2. The 
priming rouiines 304-2 are preferably part oflhe browser, but utili^^e the appropriate application 

25 programming interface (API) of ihe operating system software to implemenl the printing facility of 
the mobile phone. 

The WML decoder 301 is operated in conjunction with The WML cache 302, display module 
303 and printing module 304 to print The WML data when the print option oflhe browser is selected 
by the user. In particular, WML decoder 301 supports different line lengths, output buffers and 
30 handlers. This is especially importanl since the character width of the display 207 controlled by 
display module 303 is typically much narrower than the character width oflhe priming facility 
controller by priming module 304. WML decoder 301 makes the necessar>' conversions and wrap- 
arounds so that the decoded WML data displayed on display 207 can be suitably printed. 

Hriiuing to an external printer is carried out by directing control circuitry 103 to try lo 
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esiabiisli a conneciion lo a printer via the infrared port 202. Preferably, the infrared communication 
is carried oui using Bluetooth wireless transfer. Hie driver for this service is integrated into the 
source code of the pre-installed operating system since communication with an infrared port is not 
noniKilly required for a mobile phone, in one aspect of the invention, the driver is able to transmit 
dat:i via infrared port 202 from sources other than the browser. For example, it may be used to send 
out data for printing a phonebook, calendar, etc. If the connection to the printer is established, the 
proiii-am $cnih a pace of data to the primer. If the infrared port 202 is unable to make a connection to 
the printer or there isn't any receiving printer, an error message is displayed to alert the usen 

While the foregoing has described what are considered to be example embodiments of the 
inveniion. it is iinderslood that various modilkations may be made therein and that the invention may 
be in»plemenled in various forms and embodiments, and that it may be applied in numerous 
applications, only some of which have been described herein. It is intended by the following claims 
to clnini :iit such modifications and variations. 
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CLAIMS 

1. A mobile phone comprising: 
control circ'uilry, including a processing unit; 
u memory connected to the processing unit; 

n displuy; and 

a Wireless Application Protocol (WAP) browser adapted to interpret received Wireless 
Markup Liui^uage (WML) data and display said WML data on said display, 

wherein said WAP browser includes n print option which, when selected by the user of the 
mobile phone, causes said WML data to be printed. 

2. The mobile phone recited in claim 1, wherein The WML data is stored at a location in 
said memor\- prior lo selection of the prim option. 

3. I hc mobile phone recited in claim 2, wherein said WML data is read from said location in 
said n^morx' when suid print option is selected and is decoded prior to printing. 

4. The mobile phone recited in claim 1. wherein The WML data is printed via a direct 
infrared interface to a printer. 

5. The mobile phone recited in claim 1, wherein The WML data is transferred to the printer 

using Bluetooth wireless transfer. 

6. The mobile phone recited in claim I, wherein the print option is selected by the user in 
accoidance wit!) a menu displayed on said display. 

7. The mobile phone recited in claim 6, wherein the user selects the print option by pressing 

a soft key ussociated with the menu. 

S. The mobile phone recited in claim I, wherein the print option utilizes a printing facility 
which can prim data from sources other than said WML data interpreted by said WAP browser. 

9. The mobile phone recited in claim S, wherein the printing facility can also print a phone 
book or calendar stored in the mobile phone. 
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lU. The mobile phone recited in claim 8, wherein (he chnnicter width of lines in said display 
is narrower ih;tn the character width of lines printed by said printing facility. 

1 1 . The mobile phone recited in claim 8, wherein the printing facility is included in 
operating system software of the mobile phone. 
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